

METHOD OF PERFORMING BIT MODELING AND  
CIRCUIT THAT USES THIS METHOD

FIELD OF THE INVENTION

5        This invention relates to a method of performing bit  
modeling and a circuit that uses this method. More  
specifically, the invention relates to a method of performing  
bit modeling relating to heightening of a speed of the bit  
modeling in coding of JPEG 2000 and a circuit that uses this  
10      method.

BACKGROUND OF THE INVENTION

In a coding process of JPEG 2000 (defined by ISO/IEC  
FDIS15444-1. Hereinafter, referred to as JPEG 2000), a  
15      quantization coefficient is represented by a sign bit and  
an absolute value. As for bits representing the absolute  
value in a code block unit, while up-and-down and  
right-and-left relationships of the bits are being checked  
in the order from high-order bit plane to low-order bit plane,  
20      context and decision are generated. This will be referred  
to as bit modeling.

When N0-numbered bit planes where all the bits are  
zero continue from the highest-order bit plane representing  
the absolute value in the code block, the process is executed  
25      separately.

For example, the absolute value is accuracy of M bit planes, and when the high-order  $N_0$  bits of all absolute values are zero in a certain code block, only bit planes of  $N = M - N_0$  is subject to bit modeling.

5        The highest-order bit plane being subject to bit modeling is called as MSB (Most Significant Bit plane), and the lowest-order bit plane is called as LSB (Less Significant Bit plane).

10      Data in the code block are processed in each bit plane from MSB to LSB. In each bit plane, four bits in a vertical direction make one group and are subject to the bit modeling in a raster order.

15      Fig. 14 shows the order (0 to 23) that the group is processed when the bit modeling is carried out in the code block size of horizontal 8 (0 to 7)  $\times$  vertical 12 (0 to 11).

20      In addition, Fig. 15 shows the processing order (0 to 7) of the respective bits across the group in the bit plane (four bits in the vertical direction, for example, horizontal 0  $\times$  vertical 4 (0 to 3), horizontal 1  $\times$  vertical 4 (0 to 3)).

25      The bit modeling has three kinds of coding passes: significance propagation decoding pass (hereinafter, referred to as sig pass); magnitude refinement pass (hereinafter referred to as ref pass); and cleanup pass (hereinafter, cln pass). The process is executed in the

order of the sig pass, the ref pass and the cln pass.

Namely, in this process, the bits in a certain bit plane are evaluated in the order shown in Figs. 14 and 15, and when that data should be processed with the sig pass, 5 they are processed with the sig pass, and when not, the process proceeds to the next bit.

When the code block process is ended, the bits are evaluated as the ref pass. Finally, the bits are processed with the cln pass. At this time, when a certain bit is 10 processed with the coding pass in the early processing order (priority is high), the bit is not processed with another coding passes.

Therefore, the bits are processes are processed with only one of the three kinds of the coding passes. This 15 process is repeated from MSB to LSB, but only MSB is processed with the cln pass.

For example, when  $N = 8$ , a bit modeling operation that (7 bit planes  $\times$  3 coding passes + 1 coding pass)  $\times$  (8  $\times$  12) code block size is necessary.

20 In the aforementioned conventional processing method of JPEG 2000 bit modeling, for example, when a certain code block is subject to bit modeling, one datum requires a process which is  $(N-1) \times 3 + 1$  times according to the bit plane to be processed.

25 This creates a problem that the processing speed

decreases in comparison with quantization or the like which requires only one process regardless of bit accuracy.

SUMMARY OF THE INVENTION

5        The method of performing bit modeling and a circuit that uses the method according to the present invention, in a processing method of JPEG 2000 bit modeling with a significance propagation decoding pass, a processing circuit of bit modeling simultaneously generates a context  
10      and a decision of data changing according to a state of significance flags of a bit to be processed and ambient bit group and a context and a decision of sign bits changing according to a state of the sign bits of the bit to be processed and the ambient bit group, adopts the context and decision  
15      of the sign bits only when a value of the bit to be processed is 1 and updating the significance flag, disposes of the context and the decision when the value of the bit to be processed is 0, and updates a processed flag whether the value of the bit to be processed is 1 or 0. The processing  
20      circuit is simultaneously applied to four bits in one group and processes the four bits in parallel.

      In addition, in a processing method of JPEG 2000 bit modeling with a magnitude refinement pass, a processing circuit of the bit modeling refers to significance second  
25      bit which is information about as to whether or not a bit

to be processed is processed with the magnitude refinement pass at first time, a processed flag and an significance flag so as to make a judgment as to whether or not the bit to be processed is processed, and in the case where the bit  
5 to be processed is processed with the magnitude refinement pass, generates a context and a decision of the bit so as to update the processed flag. The processing circuit is simultaneously applied to four bits in one group and processes the four bits in parallel.

10 In addition, in a processing method of JPEG 2000 bit modeling with a cleanup pass, a first processing circuit for the bit modeling, when all bits in Annie group to be processed are unprocessed, making a judgment as to whether or not the bits can be processed collectively and when all  
15 the bits in the group are insignificant, generating a special context and a decision, and a second circuit of the bit modeling for not processing processed bits and processing insignificant bits are provided. The first processing circuit is applied to one bit and the second processing circuit is applied to four bits in the group simultaneously so as to process the bits in parallel.

In addition, in a processing method of JPEG 2000 bit modeling, one bit plane is processed with three kinds of coding passes successively.

25 In addition, in a processing method of JPEG 2000 the

bit modeling, three adjacent groups in one bit plane are processed with three kinds of coding passes in parallel.

In addition, in the processing method of the bit modeling from the fifth aspect, a plurality of bits in the 5 bit plane are processed in parallel.

In addition, in the processing method of the bit modeling from the fifth or sixth aspect, a plurality of bit planes are processed in parallel.

In addition, a processing circuit using the processing 10 method of the bit modeling from the first aspect, includes: a register for storing a value of data of a bit to be processed; a register for storing significance flags and sign bits of the bit to be processed and ambient bit group; and a register for storing an unprocessed flag of the bit to be processed.

15 In addition, a processing circuit using the processing method of the bit modeling from the second aspect, includes: a register for storing a value of data of a bit to be processed; a register for storing significance flags of the bit to be processed and ambient bit group; and a register for storing 20 a significance second bit which is information about as to whether or not the bit to be processed is processed with the magnitude refinement pass at the first time.

In addition, a processing circuit using the processing method of the bit modeling from any one of the fifth, sixth 25 or eighth aspect, includes a register for storing data bits,

sign bits, processed flags, significance flags and significance second bits for a code block size.

Further, a processing circuit using the processing method of the bit modeling from any one of the fifth, sixth 5 or eighth aspect, includes a register for storing a data bit, a sign bit, a processed flag, a significance flag and a significance second bit for a bit to be processed.

Other objects and features of this invention will become apparent from the following description with 10 reference to the accompanying drawings.

#### BRIEF DESCRIPTION OF THE DRAWINGS

Fig. 1 is a diagram showing a range of data to be used in the case where a certain group is processed in bit modeling 15 of JPEG 2000 according to a first embodiment of the present invention;

Fig. 2 is a diagram showing a range of data to be used in the case where a bit O0 is processed in the bit modeling of JPEG 2000 according to the first embodiment of the present 20 invention;

Fig. 3 is a diagram showing a range of data to be used in the case where a bit O1 is processed in the bit modeling of JPEG 2000 according to the first embodiment of the present invention;

25 FIG 4 is a diagram showing a range of data to be used

in the case where a bit O2 is processed in the bit modeling of JPEG 2000 according to the first embodiment of the present invention;

Fig. 5 is a diagram showing a range of data to be used  
5 in the case where a bit O3 is processed in the bit modeling of JPEG 2000 according to the first embodiment of the present invention;

Fig. 6 is a diagram showing a range of data to be used  
in the case where three continued groups are processed  
10 according to a fifth embodiment of the present invention;

Fig. 7 is a diagram showing a range of data to be used  
in the case where a bit group O8 to O11 according to the  
fifth embodiment of the present invention;

Fig. 8 is a diagram showing a range of data to be used  
15 in the case where a bit group O4 to O7 according to the  
fifth embodiment of the present invention;

Fig. 9 is a diagram showing a range of data to be used  
in a bit group O0 to O3 according to the fifth embodiment  
of the present invention;

20 Fig. 10 is a diagram showing values of data to be  
processed which are divided into a code bit and data for  
each bit plane in the bit modeling of JPEG2000 according  
to a sixth embodiment of the present invention;

Fig. 11 is a diagram showing values of data to be subject  
25 to another process which are divided into a code bit and

data for each bit plane in the bit modeling of JPEG2000 according to the sixth embodiment of the present invention;

Fig. 12 is a diagram showing values of data to be subject to still another process which are divided into a code bit and data for each bit plane in the bit modeling of JPEG2000 according to the sixth embodiment of the present invention;

Fig. 13 is a diagram showing a range of data to be used in the case where three continued groups are processed in parallel according to a seventh embodiment of the present invention;

Fig. 14 is a diagram showing an order of groups to be processed within bit plane in a conventional bit modeling of the JPEG2000; and

Fig. 15 is a diagram showing an order of groups to be processed within another bit plane in the conventional bit modeling of JPEG2000.

#### DESCRIPTION OF THE PREFERRED EMBODIMENTS

Embodiments of the method and circuit according to the present invention will be explained below while referring to the accompanying drawings.

Fig. 1 is a diagram showing the case where a bit group of O0 to O3 in a certain bit plane of JPEG 2000 according to a first embodiment is processed. When the bit group of O0 to O3 is processed with a sig pass, information about

bits represented by  $x$  in ambient bits is required.

Fig. 2 is a diagram showing bits that are required when the bit O0 in Fig. 1 is processed. In Fig. 2,  $x0$ ,  $x1$ ,  $x2$ ,  $x3$  and  $x5$  are bits which are processed with the same 5 coding pass before the bit O0. Moreover,  $\Delta 4$ ,  $\Delta 6$  and  $\Delta 7$  are bits which are processed after the bit O0.

A condition that a bit is to be processed with the sig pass is that the bit is insignificance and ambient bits are composed of one or more significant bits.

10 Therefore, information about whether or not the bit to be processed and the ambient bits are significant (hereinafter, referred to as significance flags) is required. The significance flags are stored in a register.

15 When the bit O0 is insignificant and the ambient bit group of  $x0$  to  $\Delta 7$  include one or more significant bits, the bit is processed with the sig pass.

20 A context (hereinafter data context) is generated according to the state of the significance flag of the ambient bit groups of  $x0$  to  $\Delta 7$ , and the value of the bit O0 itself is determined as a decision (hereinafter, data decision).

When the value of the bit O0 is 1, the data is changed from insignificance to significance. For this reason, the significance flag is updated, and the sign bit is also subject to the bit modeling.

25 The sign bit process requires a sign bit of the bit

00 and sign bits of the ambient bit group of x0 to Δ7.

10 A context (hereinafter, sign bit context) is generated according to the state of the sign bits of the ambient bit group of x0 to Δ7, and a result of an XOR operation of values 5 according to the sign bit of the bit 00 and the context is determined as a decision (hereinafter, sign bit decision).

The context and the decision of the data and the context and the decision of the sign bit are generated simultaneously.

10 Only when necessary (when the value of the bit 00 is 1), the context and the decision of the sign bit is adopted.

In addition, when not necessary (the value of the bit 00 is 0), the context and the decision are disposed of so that the process can be executed in parallel.

15 In addition, even though the value of the bit 00 is 1 or 0, when the bit 00 is processed with the sig pass, information that shows "processed" in that bit plane (hereinafter, processed flag) is updated.

20 When a certain bit is processed by the sig pass, the value of the bit, the significance flags and the sign bits of the bit and the ambient bits are referred to.

Namely, a register, in which the value of the bit 00, the significance flag of the bit 00 and the ambient bit group of x0 to Δ7 and the sign bits are stored, is required.

25 In addition, a register in which the processed flag of the bit 00 should be prepared.

Fig. 3 is a diagram showing bits that are required when the bit O1 shown in Fig. 1 is processed. With reference to Fig. 3, as for a judgment as to whether or not the bit O1 is processed with the sig pass, the significance flag 5 of the ambient bit group of  $\times 0$  to  $\Delta 7$  are referred to.

In addition, since the significance flag of the bit  $\times 1$  is equal with the significance flag of the bit O0 shown in Fig. 2, it is possibly updated at the time of processing the bit O0. For this reason, the process on the bit O1 cannot 10 be started until the process on the bit O0 is ended. However, when the bit O1 is processed, if it is understood as to whether or not the significance flag of the bit  $\times 1$  is updated, the processes on the bit O1 and the bit O0 can be executed simultaneously.

15 Namely, when the bit  $\times 1$  is insignificant and its value is 1 and the ambient bit group includes one or more significant bits, a judgment is made that the bit  $\times 1$  becomes significant at a previous process with the sig pass. The significance flags of the bit  $\times 1$  and the ambient bit group and the value 20 of the bit are referred to simultaneously so that the significance flag is updated. As a result, the bit O0 and the bit O1 are processed simultaneously.

Fig. 4 is a diagram showing bits that are required when the bit O2 shown in Fig. 1 is processed. With reference 25 to Fig. 4, as for a judgment as to whether or not the bit

O2 is processed with the sig pass, significance flag of the ambient group of x0 to A7 are referred to.

Since the significance flag of the bit x1 is equal with the significance flag of the bit O1 shown in Fig. 3, 5 the significance flag of the bit x1 is possibly updated at the time of processing the bit O1. The process on the bit O2 cannot be started until the process on the bit O1 is ended. However, when the bit O2 is processed, if it is understood as to whether or not the significance flag of 10 the bit x1 is updated, the bit O1 and O2 can be processed simultaneously.

Namely, when the bit x1 is insignificant and its value is 1 and the ambient bit group includes one or more significant bits, a judgment is that the bit x1 becomes significant at 15 a previous process with the sig pass. The significance flags of the bit x1 and the ambient bit group and the value of the bit are referred to simultaneously so that x1 is updated to the significance flag. As a result, the bit O1 and the bit O2 are processed simultaneously.

20 Fig. 5 is a diagram showing bits that are required when the bit O3 shown in Fig. 1 is processed. With reference to Fig. 5, as for a judgment as to the bit O3 is processed with the sig pass, the significance flag of the ambient bit group of x0 to A7 are referred to.

25 Since the significance flag of the bit x1 is equal

with the significance flag of the bit O2 shown in Fig. 4, the significance flag of the bit  $x_1$  is possibly updated at the time of processing the bit O2. The process on the bit O3 cannot be started until the process on the bit O2 is 5 ended. However, when the bit O3 is processed, if it is understood as to whether or not the significance flag of the bit  $x_1$  is updated, the bit O2 and the bit O3 can be processed simultaneously.

10 Namely, when the bit  $x_1$  is insignificant and its value is 1 and the ambient bit group includes one or more significant bits, a judgment is made that the bit  $x_1$  becomes significant at a previous process with the sig pass. The significance flags of the bit  $x_1$  and the ambient bit group and the value of the bit are referred to simultaneously so that the bit 15  $x_1$  is updated to the significance flag. As a result, the bit O2 and the bit O3 are processed simultaneously.

According to the first embodiment, a circuit can be 20 configured so as to be capable of executing the parallel process on the bit group of O0 to O3, and making the judgment as to whether or not the data of 1 bit are processed with the sig pass, and outputting zero, one or two sets of the contexts and the decisions.

In addition, four circuits which process data of 1 bit are arranged in parallel so as to process the bits O0, 25 O1, O2 and O3 respectively. As a result, the circuit which

outputs 0 to 8 sets of contexts and decisions for one group (four data) can be configured.

There will be explained below the parallel processing method according to a second embodiment. In the second embodiment the bits shown in Fig. 1 to Fig. 5 are processed with a ref pass. Therefore, the second embodiment will be explained while referring to Fig. 1 to Fig. 5.

At first, when the bit group of O0 to O3 shown in Fig. 1 is processed with the ref pass, information about bits 10 represented by  $\times$  in the ambient group is required. When the group is classified according to the respective bits, information about ambient 8 bits is required for the bits O0, O1, O2 and O3 shown in Fig. 2 to Fig. 5.

The condition that a bit is processed with the ref 15 pass is that the bit should not be processed with the sig pass and should be significant. Therefore, information showing as to whether or not the bit to be processed is processed and significant is required.

When the bit O0 shown in Fig. 2 is unprocessed and 20 significant, it is to be processed with the ref pass. When the bit O0 is processed with the ref pass at the first time, data context is generated according to the state of the significance flag of the ambient bit group of  $\times 0$  to  $\Delta 7$ . When it is not processed with the ref pass at the first time, 25 fixed data context is generated regardless of the state of

the significance flag.

When both the cases, the value of the bit O0 itself is the data decision. When the bit O0 is processed with the ref pass, the processed flag is updated, and the 5 significance flag and the processed flag which are the same as the sig pass are used. Further, information about as to whether or not the bit O0 is processed with the ref pass at the first time (hereinafter, referred to as significance second bit) is stored in a register.

10 In Fig. 3, as for a judgment as to whether or not the bit O1 is processed with the ref pass, the processed flag and the significance flag of the bit O1 are referred to. Similarly in Figs. 4 and 5, the processed flag and the significance flag of the bit O2 and the bit O3 are referred 15 to.

In addition, in order to process the bits O0, O1, O2 and O3 shown in Fig. 2 to Fig. 5, the values of the bit group of O0 to O3 shown in Fig. 1, the processed flag and the significance flag, and the significance flag of the bits 20 O and the bits x are required.

According to the second embodiment, since the ref pass does not update the significance flag, a circuit can be configured so as to be capable of executing the parallel process on the bit groups of O0 to O3, making a judgment 25 as to whether or not the data of 1 bit are processed with

the ref pass and outputting 0 or one set of context and decision.

In addition, four circuits for processing the data of 1 bit are arranged in parallel so as to process the bits 5 O0, O1, O2 and O3 respectively. As a result, the circuit which outputs 0 to 4 sets of contexts and decisions for one group (four data) can be configured.

There will be explained below the parallel processing method according to a third embodiment. In the second 10 embodiment the bits shown in Fig. 1 to Fig. 5 are processed with a cln pass. Therefore, the second embodiment will be explained while referring to Fig. 1 to Fig. 5.

When the bit group of O0 to O3 in Fig. 1 is processed with the cln pass, information about the bits represented 15 by x in the ambient group is required. When the group is classified according to the respective bits, information about ambient 8 bits is required for the bits O0, O1, O2 and O3 shown in Fig. 2 to Fig. 5.

The condition that a bit is processed with the cln 20 pass is that the bit is unprocessed. However, since only the process with the cln pass is executed on MSB, all the bits are to be processed. Therefore, the information about as to whether or not the bit to be processed is processed is required.

25 In addition, when all the bits O0, O1, O2 and O3 shown

in Fig. 2 to Fig. 5 are unprocessed with the `cln` pass, a judgment is made as to whether or not they can be processed collectively. As for the bits  $O_0$ ,  $O_1$ ,  $O_2$  and  $O_3$  shown in Fig. 2 to Fig. 5, when all the ambient bit group of  $x_0$  to 5  $\Delta_7$  is insignificant, special context is generated (hereinafter, run length context).

In addition, when all the values of the bits  $O_0$ ,  $O_1$ ,  $O_2$  and  $O_3$  shown in Fig. 2 to Fig. 5 are zero, decision 10 (hereinafter, run length decision) 0 is generated, and the process on this group is ended.

In addition, when at least one of the values of the bits  $O_0$ ,  $O_1$ ,  $O_2$  and  $O_3$  shown in Fig. 2 to Fig. 5 is one, the run length decision is 1. At this time, a position of 15 the first bit having the value 1 in the bits  $O_0$ ,  $O_1$ ,  $O_2$  and  $O_3$  shown in Fig. 2 to Fig. 5 is represented by data of 2 bits.

Namely, when the bit  $O_0$  is the first bit having one, the position is 00, when the bit  $O_1$ , the position is 01 and similarly is 10 and 11. The two data are generated together 20 with a context which follows the run length (hereinafter, UNIFORM context), and they are output as decisions (hereinafter, UNIFORM decision).

When only the run length context is output, all the bits are still insignificant. For this reason, the 25 significance flag are not updated.

When the UNIFORM context is also output, the bit in the position shown by the UNIFORM decision is changed from insignificance to significance. For this reason, the significance flag of the bit is updated.

5        However, since the UNIFORM context itself shows that the bit in the position shown by the decision is 1. For this reason, similarly to the sig pass, the context of the sign bit of that bit is generated.

10      The method of generating the context of the sign bit with the cln pass is the same as the sig pass. When the UNIFORM decision is 11, only the process on the sign bit is executed to be ended. However, when the other cases, remaining bits are processed one by one.

15      The method of processing the remaining bits is the same as the sig pass except that all ambient bits of the bit are processed although they are insignificant. Moreover, since the bits before the position shown by the UNIFORM decision are still insignificant, the significance flag is not updated.

20      According to the third embodiment, when a group of bits is not to be processed for the run length context, the unprocessed bits in the bits in the group are processed one by one. Moreover, bits after the UNIFORM context or unprocessed bits, which are not to be processed for the run length context, are subject to the same process as the sig

pass. For this reason, the same circuit as the sig pass can be configured.

In addition, in the case of using the sig pass, the circuit is configured so as to process the independent bits 5 in parallel and outputs 0 to 8 sets of contexts and decisions. However, according to the cln pass, the circuit processes the context and decision of 0 run length and processes the context and decision of UNIFORM in parallel. Moreover, after the followings are taken into consideration:

10     • in the case of including the 0 run length context  
        - as to whether or not the UNIFORM context is included  
        - a number of bits after the UNIFORM context; and  
   • in the case of non-including the 0 run length context  
        - a number of bits to be processed with the cln pass,  
15     the circuit can be configured so as to calculate the contexts and decisions of 0 run length, UNIFORM and the respective bits and output 0 to 10 sets of contexts and decisions.

The first to third embodiments explained the individual circuit configurations for the respective coding 20 passes. However, in the fourth embodiment, one group in one bit plane is processed simultaneously by the circuits of the first to third embodiments.

In this case, since three kinds of coding passes use information commonly, it is necessary to store significance 25 flag, significance second bit and processed flag for a code

block size into a register.

In addition, it is necessary to store sign bit and data bits of a bit plane to be processed for the code block size or for a portion to be processed actually into a register.

5 Moreover, in the case where they are read for each coding pass, it is necessary to store them for the reading into the register.

According to the fourth embodiment, the processing speed can be higher than the first to third embodiments.

10 Fig. 6 is a diagram showing a range of data to be used in the case where three continued groups are processed according to the fifth embodiment. The fourth embodiment explained the method of processing one group in one bit plane is processed simultaneously with three kinds of coding 15 passes.

However, a certain bit plane in a code block is processed with in the order of the sig pass, the ref pass and the cln pass. Since there exist restrictions such that the respective bits are processed with only one coding pass 20 and the significance flags are updated by a plurality of passes such as the sig pass and the cln pass, in order to obtain the accurate bit modeling, it is necessary to execute the processes with the respective coding passes.

Namely, in a certain bit plane, the four bits are 25 processed simultaneously, but actually they are processed

one by one with three kinds of coding passes. As a result, it is necessary to suppress an operating frequency of the circuit. In order to solve this problem, the fifth embodiment adopts the method of processing grooves which 5 continues in the horizontal direction (bit group of O0 to O3, bit group of O4 to O7, bit group of O8 to O11) with different coding passes.

Fig. 7 is a diagram showing a range of data to be used in the case where the bit group of O8 to O11 is processed. 10 Moreover, Fig. 8 is a diagram showing a range of data to be used in the case where the bit group of O4 to O7 is processed. Further, Fig. 9 is a diagram showing a range of data to be used in the case where the bit group of O0 to O3 is processed.

The sig pass is insignificant and is a coding pass 15 used for processing when the ambient bits include one or more significant bits. The process with the sig pass can be first executed without any restriction from the other two passes.

In the three groups shown in Fig. 6, the sig pass is 20 a coding pass for processing the bit group of O8 to O11, and Fig. 7 is the use range of its data. Since the bit group of O8 to O11 is processed with the sig pass, the processed flag and the significance flag of the bit group of O8 to O11 are updated according to the condition.

25 The bit groups of x5 to x8, the bit group of O0 to

16        O3 and the bit group of O4 to O7 in Fig. 6 to Fig. 9 have  
17        been already processed with the sig pass.

18        Next, since the ref pass is a coding pass for processing  
19        significant data, it is necessary to consider as to whether  
20        or not the data are significant at the time of the process.

21        In order to obtain as to whether or not the bit has  
22        been already significant, the significance flag is referred  
23        to. However, when the bit is processed with the sig pass  
24        of the same bit plane to be significant, it cannot be  
25        processed.

26        Namely, since it is necessary to make a judgment as  
27        to whether or not the bit is processed with the sig pass,  
28        the bit cannot be processed with the ref pass simultaneously  
29        with the sig pass.

30        In the three groups shown in Fig. 6, the ref pass is  
31        a coding pass for processing the bit group of O4 to O7,  
32        and Fig. 8 is the use range of that data. Since the bit  
33        group of O4 to O7 is processed with the ref pass, the processed  
34        flag and the significance flag of the bit group of O4 to  
35        O7 are referred to so that the unprocessed flag is updated  
36        according to the condition.

37        The bit group of O8 to O11 is processed with the sig  
38        pass, and the bit group of O4 to O7 is processed with the  
39        ref pass so that the flag of the bit group of O4 to O7 which  
40        has been updated with the sig pass can be referred to with

the ref pass.

In addition, the fifth embodiment explained the structure that the groups which are processed with the sig pass and the ref pass are shifted by one group in the horizontal direction in order to minimize the circuit scale, but the groups may be shifted by two groups.

The bit group of x5 to x8 and the bit group of O0 to O3 in Figs. 6, 8 and 9 have been already processed with the ref pass.

10 In addition, the cln pass is insignificant, and is a coding pass for processing data which have not been processed with the sig pass. In the fifth embodiment, the significant data have been already processed with the ref pass, and the data in insignificant data which have not been 15 processed with the sig pass are all unprocessed data. For this reason, the processed flag is referred to, and only the unprocessed data are processed.

Since it is necessary to refer to the significance flags of the bit to be processed and the ambient bits, the 20 data cannot be processed with the cln pass simultaneously with the sig pass.

In the three groups shown in Fig. 6, the cln pass is a coding pass for processing the bit group of O0 to O3, and Fig. 9 shows a use range of its data. Since the bit 25 group of O0 to O3 is processed with the cln pass, the

significance flag of the bit groups of O4 to O7 and the processed flag of the bit group of O0 to O3 are referred to, and the significance flag is updated according to the condition.

5        In addition, the bit group of x5 to x8 in Figs. 6 and 9 have been already processed with the cln pass.

The bit group of O8 to O11 is processed with the sig pass, and the bit group of O4 to O7 is processed with the ref pass, and the bit group of O0 to O3 is processed with 10 the cln pass. As a result, the flags of the bit group of O0 to O3 and the bit group of O4 to O7, which have been updated with the sig pass and the ref pass, can be referred to with the cln pass.

In addition, the fifth embodiment explained the 15 structure that the groups to be processed with the sig pass and the ref pass are shifted by one group in the horizontal direction in order to minimize the circuit scale. However, a number of groups to be processed with the sig pass, the ref pass and the cln pass may be arbitrary.

20        When the processes with three kinds of coding passes are executed in parallel in the above structure, four data can be processed in parallel with three kinds of coding passes by the same method as the first to fourth embodiments.

In addition, in Fig. 6, the bit group of  $\Delta 9$  to  $\Delta 12$  25 is processed with the sig pass, the bit group of O8 to O11

is processed with the ref pass, and the bit group of O4 to O7 is processed with the cln pass. Namely, the groups to be processed are shifted so that the processes can be executed continuously.

5        The respective coding passes output 0 to 10 sets of contexts and decisions, but it is necessary to store these data for each coding pass.

According to the fifth embodiment, it is necessary to store the significance flags and the significance second 10 bit information for the code block size into the register. However, since the processes with three kinds of the coding passes are executed at the same time, only parts of the sign bits, the data bit of the bit plane to be processed, and the processed flag which is to be processed actually may 15 be stored in the register.

In addition, as shown in Fig. 6, in the case where intervals of the groups to be processed with the respective coding passes are one group, a portion to be processed becomes 30 bits of O,  $\Delta$  and  $\times$  with sign bits, or 20 bits of  $\times 5$  to 20  $\times 8$  and O0 to O11 and  $\Delta 9$  to  $\Delta 12$  with data bits and processed flag.

Therefore, in comparison with the first to fourth embodiments, the processes can be executed at higher speed and the circuit scale can be reduced.

25        There will be explained below the parallel processing

method according to a sixth embodiment. This is a method of processing portions where the significance flags and the significance second bits in Fig. 6 are to be processed (30 bits of 0,  $\Delta$  and  $\times$  (significance flag), 20 bits of  $\times 5$  to  $\times 8$ , 00 to 011 and  $\Delta 9$  to  $\Delta 12$  (significance second bit)) with a register amount.

The significance flag is required for a code block size because while the bit modeling from MSB to LSB is being carried out, since information should be used commonly, it 10 is necessary to hold the information.

However, in the process on a certain bit plane, the state after the process on the previous bit plane may be understood. Therefore, if the state after the process on the previous bit plane can be previously calculated, it is 15 not necessary to use the information commonly between the bit planes.

The sixth embodiment adopts a method of checking a value of data to be processed, and making a judgment as to whether or not a bit, a value of which is 1, exists in higher 20 position than a bit plane to be processed.

Fig. 10 is a diagram showing values of one datum to be processed with bit modeling divided into a sign bit and absolute values. With reference to Fig. 10, since all values from MSB to the bit one higher than a certain bit plane to 25 be processed are zero, the significance flag of the data

before the process with the sig pass is insignificant.

In addition, in Fig. 11, since the values from MSB to the bit one higher than the bit plane to be processed are 1, the significance flag of the data before the process 5 with the sig pass is significant.

If this is executed when data bits are read for each bit plane, it is not necessary to use information commonly between the bit planes. For this reason, a number of registers for the significance flags can be reduced.

10 Therefore, the significance flags may have a number of registers for 30 bits of 0, Δ and × in Fig. 6.

In addition, similarly as for the significance second bits, a bit plane to be processed with the ref pass at the first time, namely, a bit plane which is next to a significant 15 bit plane is previously calculated so that it is not necessary to use information commonly between bit planes.

In the sixth embodiment, data to be processed are checked, and a judgment is made as to whether or not the value one bit higher than the bit plane to be processed is 20 1 and all the bits higher than the value are 0.

With reference to Fig. 10, since all the values of the bits higher than the bit plane to be processed are 0, they do not become the significance second bits. Moreover, in Fig. 11, since the value of the bit one higher than the 25 bit plane to be processed is 1 and all the values of the

higher bits than the value are 0, they become the significant second bits.

This is executed when the data bits are read for each bit plane so that it is not necessary to use information 5 commonly between bit planes. For this reason, a number of registers of the significant second bits can be reduced.

Therefore, the significant second bits may have registers for 20 bits of  $\times 5$  to  $\times 8$ , 00 to 011, A9 to A12 shown in Fig. 6.

10 In the sixth embodiment, the circuit, which executes the processes with three kinds of coding passes in parallel on one bit plane, and this circuit is a basic circuit of the following embodiments.

15 The seventh embodiment adopts a processing method using a plurality of circuits of the sixth embodiment for one bit plane. Fig. 13 is a diagram showing a range of data to be used in the case where three continued groups are processed in parallel. This uses the two circuits explained in the sixth embodiment for the bit groups of 0000 to 0011 20 and 0100 to 0111.

With reference to Fig. 13, the same circuit as the sixth embodiment is used for the bit group of 0000 to 0011 so as to directly process them. Moreover, since the bit group of  $\times 100$  to  $\times 104$  are data which are originally processed 25 before the bit group of 0100 to 0111, it is necessary to

previously calculate significance flags.

The sixth embodiment explained the method of calculating the significance flag up to the bit plane one bit higher than the bit plane to be processed. However, 5 in the seventh embodiment, information after a process of a group one step upper in the vertical direction is required. This can be calculated by taking data of the bit plane to be processed as well as the method in the sixth embodiment into consideration.

10 There will be explained below the case where  $\times 100$  shown in Fig. 13 has the values shown in Fig. 10 to Fig. 12.

In Fig. 10, since all the values from MSB to the bit plane to be processed are zero, the significance flag is 15 insignificant. In Fig. 11, since there is a bit having the value of 1 from MSB to one bit higher than the bit plane to be processed,  $\times 100$  is significant.

In addition, in Fig. 12, since there is a bit having the value of 1 from MSB to the bit plane to be processed (in this case, bit plane to be processed),  $\times 100$  is significant. 20 In such a manner, the significance flag of up to the group one-stage higher in the vertical direction can be calculated.

However, the same processes as the first to sixth embodiments are executed on the bit group of  $\times 105$  to  $\times 108$  and the bit group of  $\Delta 109$  to  $\Delta 117$ . For example, the bit 25  $\Delta 117$  has the value shown in Fig. 12, it becomes insignificant.

According to the seventh embodiment, the parallel processes can be executed on a plurality of groups in one bit planes. Moreover, the seventh embodiment explained the example that the groups which continue in the vertical 5 direction are processed, but intervals of the groups in the vertical direction are not limited to 1 and may be arbitrary. A number of the circuits similar to the sixth embodiment which execute the processes in parallel may be arbitrary number of not less than two. Here, when two parallel circuits 10 are provided, the circuit scale is doubled, and the processing performance is also doubled.

Further, there will be explained below the method of executing the processes on different bit planes in parallel in the eighth embodiment (not shown). This parallel 15 processes can be executed on a plurality of bit planes (arbitrary number of not less than two) by simultaneously using the method explained in the sixth embodiment for different bit planes.

In addition, in the eighth embodiment, when two 20 parallel circuits are provided, the circuit scale is doubled, and the processing performance is also doubled.

Further, the same circuit as the seventh embodiment can be simultaneously used for different bit planes. In this case, an arbitrary number of bit planes can be processed 25 in parallel.

As for a processing method of JPEG 2000 bit modeling and a processing circuit using the method according to the present invention, in a processing method with a significance propagation decoding pass, the processing circuit of the 5 bit modeling is simultaneously applied to four bits of one group and processes the four bits in parallel so that the processing speed can be heightened. The processing circuit simultaneously generates a context and a decision of data changing according to a state of significance flags of a 10 bit to be processed and an ambient bit group, and a context and a decision of sign bits changing according to a state of the sign bits of the bit to be processed and the ambient bit group, and adopts the context and the decision of the sign bits only when the value of the bit to be processed 15 is 1 so as to update the significance flags, disposes of the context and the decision when the value of the bit to be processed is 0, and updates processed flag whether the value of the bit to be processed is 1 or 0.

In addition, in a processing method of JPEG 2000 bit 20 modeling with magnitude refinement pass, the processing circuit of bit modeling is simultaneously applied to four bits in one group and processes the four bits in parallel so that the processing speed can be further heightened. The processing circuit refers to a significance second bit which 25 is information about as to whether or not the bit to be

processed is processed with the magnitude refinement pass at the first time, the processed flag and the significance flag so as to make a judgment as to whether or not the bit is processed, and generates a context and a decision of the 5 bit to be processed in the case where the bit is processed with the magnitude refinement pass, and updates the processed flag.

In addition, in a processing method of bit modeling with JPEG 2000 cleanup pass, a first processing circuit of 10 bit modeling and a second processing circuit of bit modeling are provided and simultaneously applied to one bit and four bits in one group and process the bits in parallel so that the processing speed can be further heightened. The first processing circuit, when all bits in a group to be processed 15 are unprocessed, makes a judgment as to whether or not they can be processed collectively, and when all the bits in one group are insignificant, generates special context and decision. The second processing circuit does not process processed bits, and processes insignificant bits.

20 In addition, in the processing method of JPEG 2000 bit modeling, since one bit plane is processed with three kinds of the coding passes successively, the processing speed can be further heightened.

25 In addition, in the processing method of JPEG 2000 bit modeling, since adjacent three groups in one bit plane

are processed in parallel with three kinds of the coding passes, the processing speed can be further heightened, and the circuit scale can be reduced.

In addition, in the processing method of bit modeling  
5 from a fifth aspect, since a plurality of bits in one bit plane are processed in parallel, the processing speed can be further heightened, and the circuit scale can be reduced.

Further, in the processing method of bit modeling from  
fifth or sixth aspect, since a plurality of bit planes are  
10 processed in parallel, the processing speed can be further heightened.

In addition, in the processing circuit using the processing method bit modeling from a first aspect, a register which stores a value of data of a certain bit to  
15 be processed, a register which stores the significance flags and sign bits of the bit to be processed and the ambient bit group, and a register which stores the processed flag of the bit to be processed are provided. As a result, the processing speed can be heightened.

20 In addition, in the processing circuit using the method of performing bit modeling from a second aspect, a register which stores a value of data of a certain bit to be processed, a register which stores significance flags of the bit to be processed and the ambient bit group, and a register which  
25 stores a significance second bit which is information about

as to whether or not the bit to be processed is processed at first time with the magnitude refinement pass are provided. As a result, the processing speed can be further heightened.

In addition, in the processing circuit using the method of performing bit modeling from fifth to, sixth or eighth aspect, registers which stores data bits, sign bits, processed flags and significance flags and significance second bits for code block size are provided. As a result, the processing speed can be heightened, and the circuit scale can be reduced.

Further, in the processing circuit using the method of performing bit modeling from the fifth, sixth or eighth aspect, registers which stores data bit, sign bit, processed flag, significance flag and significance second bit for the bit to be processed are provided. As a result, the processing speed can be further heightened, and the circuit scale can be reduced.

Although the invention has been described with respect to a specific embodiment for a complete and clear disclosure, the appended claims are not to be thus limited but are to be construed as embodying all modifications and alternative constructions that may occur to one skilled in the art which fairly fall within the basic teaching herein set forth.